# A 1-Bit Memory



## A 1-Bit Memory



# Setting a 1-Bit Memory



# Initializing a 1-Bit Memory



#### From S-R Latches to D-Latches





Worksheet!























# Small Memory, "Big" Memory...





| Instruction Register | Load 5 into Register 0 |
|----------------------|------------------------|
|                      |                        |
| Register 0           | 0                      |
| Register 1           | 0                      |
| Register 2           | 0                      |
| Register 3           | 0                      |

| Instruction Register | Load 5 into Register 0 |  |
|----------------------|------------------------|--|
|                      |                        |  |
| Register 0           | 5                      |  |
| Register 1           | 0                      |  |
| Register 2           | 0                      |  |
| Register 3           | 0                      |  |

| Instruction Register | Register2=Register0+Register1 |
|----------------------|-------------------------------|
|                      |                               |
| Register 0           | 5                             |
| Register 1           | 0                             |
| Register 2           | 0                             |
| Register 3           | 0                             |

| Instruction Register | Register2=Register0+Register1 |
|----------------------|-------------------------------|
|                      |                               |
| Register 0           | 5                             |
| Register 1           | 0                             |
| Register 2           | 5                             |
| Register 3           | 0                             |

| Instruction Register Register2=Register0+Register2 |   |  |  |
|----------------------------------------------------|---|--|--|
|                                                    |   |  |  |
| Register 0                                         | 5 |  |  |
| Register 1                                         | 0 |  |  |
| Register 2                                         | 5 |  |  |
| Register 3                                         | 0 |  |  |

| Instruction Register Register2=Register0+Register2 |    |  |
|----------------------------------------------------|----|--|
|                                                    |    |  |
| Register 0                                         | 5  |  |
| Register 1                                         | 0  |  |
| Register 2                                         | 10 |  |
| Register 3                                         | 0  |  |













## A Computer!

| Program Counter      | 00000000 |
|----------------------|----------|
| Instruction Register | 00000000 |
| Register 0           | 00000010 |
| Register 1           | 00000000 |
| Register 2           | 0000001  |
| Register 3           | 00000000 |

|          | Binary   | Base 10 |
|----------|----------|---------|
| 00110010 | 00000000 | 0       |
| 00011010 | 00000001 | 1       |
| 10001100 | 00000010 | 2       |
|          | 00000011 | 3       |
|          | 00000100 | 4       |
|          |          |         |
|          |          |         |
|          |          |         |
|          |          |         |
|          |          |         |
|          | 11111111 | 255     |

**Memory Location** 

Central Processing Unit (CPU)

Central Processing Unit (CPU)

#### A Computer!

**Memory Location** 



Central Processing Unit (CPU)

#### A Computer!

**Memory Location** 



#### A Computer!

| Program Counter      | 0000000  |
|----------------------|----------|
|                      |          |
| Instruction Register | 00110010 |
|                      |          |
| Register 0           | 0000010  |
| <u> </u>             |          |
| Register 1           | 0000000  |
|                      |          |
| Register 2           | 0000001  |
|                      | 0000000  |
| Register 3           | 00000000 |
|                      |          |

|          | Binary   | Base 10 |
|----------|----------|---------|
| 00110010 | 00000000 | 0       |
| 00011010 | 0000001  | 1       |
| 10001100 | 00000010 | 2       |
|          | 00000011 | 3       |
|          | 00000100 | 4       |
|          |          |         |
|          |          |         |
|          |          |         |
|          |          |         |
|          |          |         |
|          | 11111111 | 255     |

**Memory Location** 

Central Processing Unit (CPU)

#### A Computer!



Central Processing Unit (CPU)

Memory

**Memory Location** 

#### A Computer!



Central Processing Unit (CPU)

Memory

**Memory Location** 

#### A Computer!

**Program Counter Incremented** 

**Memory Location** 

|                      | <b>↓</b> |
|----------------------|----------|
| Program Counter      | 0000001  |
| Instruction Register | 00110010 |
| Register 0           | 0000010  |
| Register 1           | 0000000  |
| Register 2           | 0000001  |
| Register 3           | 00000011 |

|          | Binary   | Base 10 |
|----------|----------|---------|
| 00110010 | 00000000 | 0       |
| 00011010 | 00000001 | 1       |
| 10001100 | 00000010 | 2       |
|          | 00000011 | 3       |
|          | 00000100 | 4       |
|          |          |         |

11111111 255

Central Processing Unit (CPU)

Central Processing Unit (CPU)

#### A Computer!

**Memory Location** 



Memory



Central Processing Unit (CPU)

Memory



# A Computer!



Central Processing Unit (CPU)

Memory



# A Computer!



Central Processing Unit (CPU)

Memory



# A Computer!

Program Counter Incremented

Memory Location

|          | Binary   | Base 10 |
|----------|----------|---------|
| 00110010 | 00000000 | 0       |
| 00011010 | 00000001 | 1       |
| 10001100 | 00000010 | 2       |
|          | 00000011 | 3       |
|          | 00000100 | 4       |
|          |          |         |
|          |          |         |

11111111

255

|                      | <b>*</b> |
|----------------------|----------|
| Program Counter      | 00000010 |
| Instruction Register | 00011010 |
| Register 0           | 0000010  |
| Register 1           | 0000010  |
| Register 2           | 0000001  |
| Register 3           | 00000011 |

Central Processing Unit (CPU)

Memory

#### A Computer!





Central Processing Unit (CPU)

#### A Computer!



#### A Computer!



#### A Computer!



A Computer! add subtract multiply **Memory Location** divide Base 10 Binary 00110010 00000000 0 8 bit 00011010 0000001 0000010 1 **Program Counter** address 10001100 0000010 2 00011010 00000011 3 **Instruction Register** 00000100 4 00000010 Register 0 8 bit 0000010 data in Register 1 0000001 Register 2 00000011 Register 3 Read 11111111 255 Write Memory Central Processing Unit (CPU)

A Computer! add subtract multiply **Memory Location** divide Base 10 Binary 00110010 00000000 0 8 bit 00011010 0000001 0000010 1 **Program Counter** address 10001100 0000010 2 10001100 00000011 3 Instruction Register 00000100 4 00000010 Register 0 8 bit 8 bit data 0000010 data in out Register 1 0000001 Register 2 00000011 Register 3 Read 11111111 255 Write Memory Central Processing Unit (CPU)

addsubtractmultiplydivide

#### A Computer!



addsubtractmultiplydivide

#### A Computer!



# The von Neumann "Architecture"



John von Neumann

|                     |                                      | 301111 V011 1                    |
|---------------------|--------------------------------------|----------------------------------|
| Multip              | sters, etc.                          | RAM random access memory         |
|                     | Progra m Counte Instruction Register | 00110010<br>00011010<br>10001100 |
| r0                  | Large but                            |                                  |
| few fast<br>gisters | slow memory                          |                                  |
| r15                 |                                      |                                  |



2006
Intel Core 2 Duo
3 GHz clock
64-bit processor
291 million transistors
65 nm wires





It doesn't look all that fast to me!



# A Short Aside...

CPU



Main Memory (RAM)



Disk Drive



16 Registers ("Bytes")

1 cycle

Actual <10<sup>-9</sup> sec time:

If "cycle" = 1 sec 1 sec 109 "Bytes" of memory

200 cycles

<10<sup>-7</sup> sec

10<sup>12</sup> "Bytes" of memory

? cycles

<10<sup>-2</sup> sec